// 主题变量
:root {
  // 主色调
  --primary-color: #409EFF;
  --success-color: #67C23A;
  --warning-color: #E6A23C;
  --danger-color: #F56C6C;
  --info-color: #909399;

  // 文字颜色
  --text-primary: #303133;
  --text-regular: #606266;
  --text-secondary: #909399;
  --text-placeholder: #C0C4CC;

  // 边框颜色
  --border-color: #DCDFE6;
  --border-color-light: #E4E7ED;
  --border-color-lighter: #EBEEF5;

  // 背景颜色
  --bg-color: #FFFFFF;
  --bg-color-page: #F2F3F5;
  --bg-color-overlay: #FFFFFF;

  // 阴影
  --box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  --box-shadow-light: 0 2px 4px rgba(0, 0, 0, .12), 0 0 6px rgba(0, 0, 0, .04);
  --box-shadow-dark: 0 2px 4px rgba(0, 0, 0, .12), 0 0 6px rgba(0, 0, 0, .12);
}

// 暗色主题变量
[data-theme='dark'] {
  --text-primary: #E5EAF3;
  --text-regular: #CFD3DC;
  --text-secondary: #A3A6AD;
  --text-placeholder: #8D9095;

  --border-color: #4C4D4F;
  --border-color-light: #363637;
  --border-color-lighter: #2B2B2C;

  --bg-color: #141414;
  --bg-color-page: #0A0A0A;
  --bg-color-overlay: #1D1E1F;

  --box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.3);
  --box-shadow-light: 0 2px 4px rgba(0, 0, 0, .32), 0 0 6px rgba(0, 0, 0, .24);
  --box-shadow-dark: 0 2px 4px rgba(0, 0, 0, .32), 0 0 6px rgba(0, 0, 0, .32);
}

// 全局样式
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  height: 100%;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 14px;
  color: var(--text-primary);
  background-color: var(--bg-color-page);
}

// 滚动条样式
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-thumb {
  background-color: var(--text-placeholder);
  border-radius: 3px;
}

::-webkit-scrollbar-track {
  background-color: var(--border-color-lighter);
}

// 通用动画
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.3s ease;
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}

// 通用卡片样式
.el-card {
  border: none;
  border-radius: 8px;
  box-shadow: var(--box-shadow-light) !important;
  transition: transform 0.3s, box-shadow 0.3s;

  &:hover {
    transform: translateY(-2px);
    box-shadow: var(--box-shadow) !important;
  }

  .el-card__header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color-lighter);
  }
}

// 通用表单样式
.el-form {
  .el-form-item__label {
    font-weight: 500;
  }
}

// 通用按钮样式
.el-button {
  &.is-round {
    padding-left: 24px;
    padding-right: 24px;
  }

  &--primary {
    &:not(.is-plain) {
      &:hover,
      &:focus {
        background: var(--primary-color);
        border-color: var(--primary-color);
        opacity: 0.8;
      }
    }
  }
}

// 通用图标样式
.el-icon {
  vertical-align: middle;
}

// 通用加载状态
.loading-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 200px;
}

// 通用空状态
.empty-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 200px;
  color: var(--text-secondary);

  .el-icon {
    font-size: 48px;
    margin-bottom: 16px;
  }
} 